package com.hardy.leecode;

/**
 * Author: Hardy
 * Date:   2020/11/3
 * Description:
 * -
 * 941. 有效的山脉数组
 * 给定一个整数数组 A，如果它是有效的山脉数组就返回 true，否则返回 false。
 * <p>
 * 让我们回顾一下，如果 A 满足下述条件，那么它是一个山脉数组：
 * <p>
 * A.length >= 3
 * 在 0 < i < A.length - 1 条件下，存在 i 使得：
 * A[0] < A[1] < ... A[i-1] < A[i]
 * A[i] > A[i+1] > ... > A[A.length - 1]
 * <p>
 * 输入：[2,1]
 * 输出：false
 * 示例 2：
 * <p>
 * 输入：[3,5,5]
 * 输出：false
 * 示例 3：
 * <p>
 * 输入：[0,3,2,1]
 * 输出：true
 * <p>
 * 提示：
 * <p>
 * 0 <= A.length <= 10000
 * 0 <= A[i] <= 10000
 **/
public class Que941 {

    public static void main(String[] args) {

        int[] a = {0, 1, 2, 3};

        System.out.println(new Solution().validMountainArray(a));
    }

    static class Solution {

        public boolean validMountainArray(int[] A) {
            if (A.length < 3) return false;

            int i = 0;
            int j = A.length - 1;

            while (i + 1 < j) {
                if (A[i] < A[i + 1]) i++;
                else break;
            }

            while (i <= j - 1) {
                if (A[j] < A[j - 1]) j--;
                else break;
            }

            return i !=0 && i == j;
        }
    }
}
